Docker makes it easy to wrap your applications and services in containers so you can run them anywhere. However, as you work with Docker, it’s also easy to accumulate an excessive number of unused images, containers, and data volumes that clutter the output and consume disk space.
Docker gives you all the tools you need to clean up your system from the command line. This cheat sheet-style guide provides a quick reference to commands that are useful for freeing disk space and keeping your system organized by removing unused Docker images, containers, and volumes.
How to Use This Guide:
Note: The command substitution syntax, command $(command)
, used in the commands is available in many popular shells, such as bash, zsh, and Windows Powershell.
If you want a 1-click way to deploy a Docker application to a live server, take a look at DigitalOcean App Platform.
Docker provides a single command that will clean up any resources — images, containers, volumes, and networks — that are dangling (not tagged or associated with a container):
To additionally remove any stopped containers and all unused images (not just dangling images), add the -a
flag to the command:
Use the docker images
command with the -a
flag to locate the ID of the images you want to remove. This will show you every image, including intermediate image layers. When you’ve located the images you want to delete, you can pass their ID or tag to docker rmi
:
List:
Remove:
Note: The -a
or --all
flag in the docker images
command displays all the Docker images, including intermediate ones that are not referenced by any tags. By default, docker images
shows only the images with at least one tag. However, there may be some images without any tags that are still taking up disk space on the system. The -a
flag can be helpful in identifying images that can be pruned to save disk space. When used with the docker rmi
command, the -f
or --force
flag can also be used to remove images with no tags.
Docker images consist of multiple layers. Dangling images are layers that have no relationship to any tagged images. They no longer serve a purpose and consume disk space. They can be located by adding the filter flag -f
with a value of dangling=true
to the docker images
command. When you’re sure you want to delete them, you can use the docker image prune
command:
Note: If you build an image without tagging it, the image will appear on the list of dangling images because it has no association with a tagged image. You can avoid this situation by providing a tag when you build, and you can retroactively tag an image with the docker tag
command.
List:
Remove:
You can find all the images that match a pattern using a combination of docker images
and grep
. Once you’re satisfied, you can delete them by using awk
to pass the IDs to docker rmi
. Note that these utilities are not supplied by Docker and are not necessarily available on all systems:
List:
Remove:
All the Docker images on a system can be listed by adding -a
to the docker images
command. Once you’re sure you want to delete them all, you can add the -q
flag to pass the image ID to docker rmi
:
List:
Remove:
Use the docker ps
command with the -a
flag to locate the name or ID of the containers you want to remove:
List:
Remove:
If you know when you’re creating a container that you won’t want to keep it around once you’re done, you can run docker run --rm
to automatically delete it when it exits:
Run and Remove:
You can locate containers using docker ps -a
and filter them by their status: created
, restarting
, running
, paused
, or exited
. To review the list of exited
containers, use the -f
flag to filter based on status. When you’ve verified you want to remove those containers, use -q
to pass the IDs to the docker rm
command:
List:
Remove:
Docker filters can be combined by repeating the filter flag with an additional value. This results in a list of containers that meet either condition. For example, if you want to delete all containers marked as either created
(a state which can result when you run a container with an invalid command) or exited
, you can use two filters:
List:
Remove:
You can find all the containers that match a pattern using a combination of docker ps
and grep
. When you’re satisfied that you have the list you want to delete, you can use awk
and xargs
to supply the ID to docker rm
. Note that these utilities are not supplied by Docker and are not necessarily available on all systems:
List:
Remove:
You can review the containers on your system with docker ps
. Adding the -a
flag will show all containers. When you’re sure you want to delete them, you can add the -q
flag to supply the IDs to the docker stop
and docker rm
commands:
List:
Remove:
Use the docker volume ls
command to locate the volume name or names you wish to delete. Then you can remove one or more volumes with the docker volume rm
command:
List:
Remove:
Since the point of volumes is to exist independent from containers, when a container is removed, a volume is not automatically removed at the same time. When a volume exists and is no longer connected to any containers, it’s called a dangling volume. To locate them to confirm you want to remove them, you can use the docker volume ls
command with a filter to limit the results to dangling volumes. When you’re satisfied with the list, you can remove them all with docker volume prune
:
List:
Remove:
If you create an unnamed volume, it can be deleted at the same time as the container with the -v
flag. Note that this only works with unnamed volumes. When the container is successfully removed, its ID is displayed. Note that no reference is made to the removal of the volume. If it is unnamed, it is silently removed from the system. If it is named, it silently stays present.
Remove:
This guide covers some of the common commands used to remove images, containers, and volumes with Docker. There are many other combinations and flags that can be used with each. For a comprehensive guide to what’s available, see the Docker documentation for docker system prune
, docker rmi
, docker rm
, and docker volume rm
. If there are common cleanup tasks you’d like to see in the guide, please ask or make suggestions in the comments.
For a detailed look at the different components of a Docker container, check out The Docker Ecosystem: An Introduction to Common Components.
1.How do I completely remove Docker images?
To completely remove a Docker image, use the following command:
Replace <image-id>
with the ID or name of the image. If the image is in use by a container, you must first remove the container before removing the image.
2.How do I remove unused Docker images?
Unused images (dangling and untagged) can be removed using the following command:
To remove all unused images, use the --all
flag:
3.How do I clear all Docker images and cache?
To remove all Docker images, containers, volumes, and networks, use this command:
Note: This command will delete everything related to Docker, including all stopped containers and volumes.
4.How do I remove files from a Docker image?
You cannot directly modify a Docker image. Instead, create a new image without the unwanted files. Here’s how:
Start and login inside the container from the image:
Now, remove files within the container as needed.
Next, commit the changes to a new image:
5.How to remove all stopped Docker containers?
To remove all stopped containers, use:
You will be prompted for confirmation. To skip the prompt, use:
6.How do I remove old Docker containers?
To remove containers that have been inactive for a specified time, use the following:
This removes containers with exited
or created
status. Adjust the filter based on your needs.
7.Where are Docker images stored?
Docker images are stored in the Docker directory of your system. By default:
/var/lib/docker
C:\ProgramData\DockerDesktop
You can verify the storage driver and path using:
8.How do I remove a container when Docker is finished?
To automatically remove a container after it exits, use the --rm
flag when starting the container:
This ensures the container is removed as soon as it stops.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Great article. Thanks!
There is -q missing in Remove containers using more than one filter
should be docker rm $(docker ps -a -f status=exited -f status=created -q)
Super handy article!
I think the “Removing images according to a pattern” and “Remove containers according to a pattern” are mixed up.
For images:
and alternatively, I found this one to work better (as multiple tags can link to a same image):
For containers:
Thanks for this detailed useful article! For now as a punch line you can add the new alternate way :
docker system prune
See https://docs.docker.com/engine/reference/commandline/system_prune/ Can’t figure out since this new command released.This was a life saver. I am a rookie at this and it helped greatly. Thanks!
What about the build in CLI tools
And you are done!
Thanks for the document. To remove dangling images the command seems to be
docker image prune
, notdocker images purge
Nice… A quick read for the essential cmds…
An add up, use xargs with *-r * flag. Otherwise if left hand side doesn’t give any data which will trigger error
-r, --no-run-if-empty if there are no arguments, then do not run COMMAND; if this option is not given, COMMAND will be run at least once
docker images -a | grep “pattern” | awk ‘{print $3}’ | xargs -r docker rmi
That’s good, thanks for this complete post, it’s appreciated!
Thanks! It resolved my issue!